package woa.array;

import java.util.Arrays;

/**
 * 颜色分类问题
 * 给定一个包含红色、白色和蓝色，一共 n 个元素的数组，原地对它们进行排序，使得相同颜色的元素相邻，并按照红色、白色、蓝色顺序排列
 * 此题中，我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。
 * 输入：nums = [2,0,2,1,1,0]
 * 输出：[0,0,1,1,2,2]
 *
 * @author wangpeng
 * @date 2021/11/9
 */
public class SortColorProblem {

    /**
     * 单指针
     *
     * @param nums
     */
    public static void sortColors(int[] nums) {
        int t = 0;
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] == 0) {
                nums[i] = nums[t];
                nums[t] = 0;
                t++;
            }
        }

        for (int i = t; i < nums.length; i++) {
            if (nums[i] == 1) {
                nums[i] = nums[t];
                nums[t] = 1;
                t++;
            }
        }

    }

    /**
     * 双指针p0和p1
     *
     * @param nums
     */
    public static void sortColors1(int[] nums) {
        int p0 = 0, p1 = 0;
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] == 0) {
                nums[i] = nums[p0];
                nums[p0] = 0;
                if (p0 < p1) {
                    int temp = nums[p1];
                    nums[p1] = nums[i];
                    nums[i] = temp;
                }
                p0++;
                p1++;
            }
            if (nums[i] == 1) {
                nums[i] = nums[p1];
                nums[p1] = 1;
                p1++;
            }
        }
    }

    /**
     * 双指针p0和p2
     *
     * @param nums
     */
    public static void sortColors2(int[] nums) {
        int len = nums.length;
        int p0 = 0, p2 = len - 1;
        for (int i = 0; i <= p2; i++) {
            if (nums[i] == 0) {
                nums[i] = nums[p0];
                nums[p0] = 0;
                p0++;
            } else if (nums[i] == 2) {
                nums[i] = nums[p2];
                nums[p2] = 2;
                if (nums[i] != 1) {
                    i--;
                }
                p2--;
            }
        }
    }

    public static void main(String[] args) {
        int[] arr = new int[]{2,1,0,2,1,1,0,0};
        sortColors2(arr);
        System.out.println(Arrays.toString(arr));
    }
}
